--- asterisk-trunk.ORIG/channels/chan_sip.c 2009-06-26 20:34:08.732262132 +0200 +++ asterisk-trunk/channels/chan_sip.c 2009-06-26 20:38:50.869261871 +0200 @@ -11394,30 +11394,35 @@ { struct sip_request req; char from[256]; char to[256]; char tmp[80]; char addr[80]; struct sip_pvt *p; + struct sip_peer *peer; int res; char *fromdomain; char *domainport = NULL; /* exit if we are already in process with this registrar ?*/ if (r == NULL || ((auth == NULL) && (r->regstate == REG_STATE_REGSENT || r->regstate == REG_STATE_AUTHSENT))) { if (r) { ast_log(LOG_NOTICE, "Strange, trying to register %s@%s when registration already pending\n", r->username, r->hostname); } return 0; } if (r->dnsmgr == NULL) { char transport[MAXHOSTNAMELEN]; + peer = find_peer(r->hostname, NULL, TRUE, FINDPEERS, FALSE); snprintf(transport, sizeof(transport), "_sip._%s", get_transport(r->transport)); /* have to use static get_transport function */ - ast_dnsmgr_lookup(r->hostname, &r->us, &r->dnsmgr, sip_cfg.srvlookup ? transport : NULL); + ast_dnsmgr_lookup(peer ? peer->tohost : r->hostname, &r->us, &r->dnsmgr, sip_cfg.srvlookup ? transport : NULL); + if (peer) { + unref_peer(peer, "removing peer ref for dnsmgr_lookup"); + } } if (r->call) { /* We have a registration */ if (!auth) { ast_log(LOG_WARNING, "Already have a REGISTER going on to %s@%s?? \n", r->username, r->hostname); return 0; } else {